Imports System.Data
Imports CrystalDecisions.CrystalReports.Engine

Partial Class Buq_MuelleReporte
  Inherits System.Web.UI.Page

  Protected Sub form1_Load(ByVal sender As Object, ByVal e As System.EventArgs) Handles form1.Load

    Try
      Dim reporte As New ReportDocument()
      ' Detalle del documento
      reporte.Load(Server.MapPath("~\Documentos\Buq_Muelle\Reporte\rptBuq_Muelle.rpt"))

      'Datos encabezado
      Dim docBuq_Muelle As New DataAccesBuq_Muelle()
      Dim Buq_MuelleDetalle As New DataSet("DetalleDocumento")
      Buq_MuelleDetalle = docBuq_Muelle.Buq_Muelle_DetalleXML(CInt(Request.QueryString("nidDocumento")))
	  Buq_MuelleDetalle.Tables(0).TableName = "Encabezado"
	  Buq_MuelleDetalle.Tables(1).TableName = "DetalleDocumento"
	  Buq_MuelleDetalle.Tables(2).TableName = "Anexos"
	  Buq_MuelleDetalle.Tables(3).TableName = "Incidencias"
	  
	  Dim tEncabezado As DataTable=Buq_MuelleDetalle.Tables(0)
	  Dim tDetalle As DataTable=Buq_MuelleDetalle.Tables(1)
	  Dim tAnexos As DataTable=Buq_MuelleDetalle.Tables(2)
	  Dim tIncidencias As DataTable=Buq_MuelleDetalle.Tables(3)
	  
      reporte.SetParameterValue("pCodigo", tEncabezado.Rows(0)("CODIGO"))
      reporte.SetParameterValue("pFechaSolicitud", CDate(tEncabezado.Rows(0)("FECHACREACION")).ToString("dd/MM/yyyy HH:mm:ss"))
      reporte.SetParameterValue("pEmisor", tEncabezado.Rows(0)("NOMBRE"))

      'Detalle del documento
	  reporte.SetParameterValue("pvid", tDetalle.Rows(0)("vid").ToString)
      reporte.SetParameterValue("pptda_buq_muelle", tDetalle.Rows(0)("ptda_buq_muelle").ToString)
      reporte.SetParameterValue("pmuelle", tDetalle.Rows(0)("muelle").ToString)
      reporte.SetParameterValue("pf_atraque", CDate(tDetalle.Rows(0)("f_atraque")).ToString("dd/MM/yyyy HH:mm:ss"))
      reporte.SetParameterValue("ph_atraque", tDetalle.Rows(0)("h_atraque").ToString)
      reporte.SetParameterValue("pf_desatraque", CDate(tDetalle.Rows(0)("f_desatraque")).ToString("dd/MM/yyyy HH:mm:ss"))
      reporte.SetParameterValue("ph_desatraque", tDetalle.Rows(0)("h_desatraque").ToString)
      reporte.SetParameterValue("pliberado_pago_muelle", tDetalle.Rows(0)("liberado_pago_muelle").ToString)
      reporte.SetParameterValue("patraque_oficial", tDetalle.Rows(0)("atraque_oficial").ToString)
      reporte.SetParameterValue("pdesatraque_oficial", tDetalle.Rows(0)("desatraque_oficial").ToString)
      reporte.SetParameterValue("penmienda", tDetalle.Rows(0)("enmienda").ToString)
      reporte.SetParameterValue("pmal_tiempo", tDetalle.Rows(0)("mal_tiempo").ToString)
      reporte.SetParameterValue("pagenciamiento", tDetalle.Rows(0)("agenciamiento").ToString)
      reporte.SetParameterValue("pexento_pago_muelle", tDetalle.Rows(0)("exento_pago_muelle").ToString)
      reporte.SetParameterValue("pnaviera", tDetalle.Rows(0)("naviera").ToString)
      reporte.SetParameterValue("pcliente_facturar", tDetalle.Rows(0)("cliente_facturar").ToString)
      reporte.SetParameterValue("plibera_zarpe", tDetalle.Rows(0)("libera_zarpe").ToString)
      reporte.SetParameterValue("pusername", tDetalle.Rows(0)("username").ToString)
      reporte.SetParameterValue("pmov_cctm", tDetalle.Rows(0)("mov_cctm").ToString)
      reporte.SetParameterValue("pmov_cctm2", tDetalle.Rows(0)("mov_cctm2").ToString)
      reporte.SetParameterValue("pafecta_infraestructura", tDetalle.Rows(0)("afecta_infraestructura").ToString)
      
      

      'Datos Anexos
      Dim anexos As String = ""
      Dim tipos As String = ""
      For i As Integer = 0 To tAnexos.Rows.Count - 1
        anexos += tAnexos.Rows(i)("NOMBRE") + Chr(13)
        tipos += tAnexos.Rows(i)("TIPO") + Chr(13)
      Next
      reporte.SetParameterValue("pAnexos", anexos)
      reporte.SetParameterValue("pAnexoTipo", tipos)

      'Datos Incidencias
      Dim fecha As String = ""
      Dim descripcion As String = ""
      Dim emisor As String = ""
      For i As Integer = 0 To tIncidencias.Rows.Count - 1
        fecha += CDate(tIncidencias.Rows(i)("FECHAEMISION")).ToString("dd/MM/yyyy hh:mm:ss") + Chr(13)
        descripcion += tIncidencias.Rows(i)("DESCRIPCION") + Chr(13)
        emisor += tIncidencias.Rows(i)("NOMBRE") + Chr(13)
      Next
      reporte.SetParameterValue("pFechaIncidencia", fecha)
      reporte.SetParameterValue("pDescripcionIncidencia", descripcion)
      reporte.SetParameterValue("pEmisorIncidencia", emisor)


      'Cargar informacion de firma electronica
      Dim consultaFirmas As New DataAccesGenerales()
      Dim firmas As New DataTable("CasetaFirmas")
      firmas = consultaFirmas.consultarFirmas(CInt(Request.QueryString("nidDocumento")))
      Dim cadenaFirmas As String = String.Empty
      For Each datoFirma In firmas.Rows
        cadenaFirmas = cadenaFirmas & datoFirma("Firma").ToString() & " "+ Chr(13)
      Next
      reporte.SetParameterValue("pFirma", cadenaFirmas)

      'crvBuq_Muelle.ParameterFieldInfo.Clear()
      Me.crvBuq_Muelle.HasExportButton = False
      Me.crvBuq_Muelle.HasToggleGroupTreeButton = False
      Me.crvBuq_Muelle.EnableParameterPrompt = False
      'Me.crvBuq_Muelle.ParameterFieldInfo = False
      Me.crvBuq_Muelle.ReportSource = reporte

    Catch ex As Exception
      lblMensaje.Text = "Error al Cargar reporte: " + ex.Message
    End Try
  End Sub

End Class
